home *** CD-ROM | disk | FTP | other *** search
MacBinary | 1992-04-05 | 11.5 KB | [TEXT/MPS ] |
open in:
MacOS 8.1
|
Win98
|
DOS
browse contents |
view JSON data
|
view as text
This file was processed as: MacBinary
(archive/macBinary).
Confidence | Program | Detection | Match Type | Support
|
---|
66%
| dexvert
| Compact Compressed (Unix) (archive/compact)
| ext
| Supported |
10%
| dexvert
| MacBinary (archive/macBinary)
| fallback
| Supported |
1%
| dexvert
| Text File (text/txt)
| fallback
| Supported |
100%
| file
| MacBinary II, Sun Apr 5 13:55:10 1992, modified Sun Apr 5 13:55:10 1992, creator 'MPS ', type ASCII, 11054 bytes "bucket.c" , at 0x2bae 428 bytes resource
| default (weak)
| |
99%
| file
| data
| default
| |
74%
| TrID
| Macintosh plain text (MacBinary)
| default
| |
25%
| TrID
| MacBinary 2
| default (weak)
| |
100%
| siegfried
| fmt/1762 MacBinary (II)
| default
| |
100%
| lsar
| MacBinary
| default
|
|
id metadata |
---|
key | value |
---|
macFileType | [TEXT] |
macFileCreator | [MPS ] |
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 08 62 75 63 6b 65 74 | 2e 63 00 00 00 00 00 00 |..bucket|.c......|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4d 50 53 | 20 00 00 00 00 00 00 00 |.TEXTMPS| .......|
|00000050| 00 00 00 00 00 2b 2e 00 | 00 01 ac a6 04 ef 7e a6 |.....+..|......~.|
|00000060| 04 ef 7e 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |..~.....|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 92 70 00 00 |........|.....p..|
|00000080| 2f 2a 20 62 75 63 6b 65 | 74 2e 63 20 2d 20 54 68 |/* bucke|t.c - Th|
|00000090| 65 20 72 6f 75 74 69 6e | 65 73 20 66 6f 72 20 70 |e routin|es for p|
|000000a0| 6c 61 79 69 6e 67 20 77 | 69 74 68 20 68 61 73 68 |laying w|ith hash|
|000000b0| 20 62 75 63 6b 65 74 73 | 2e 20 2a 2f 0d 0d 2f 2a | buckets|. */../*|
|000000c0| 20 20 54 68 69 73 20 66 | 69 6c 65 20 69 73 20 70 | This f|ile is p|
|000000d0| 61 72 74 20 6f 66 20 47 | 44 42 4d 2c 20 74 68 65 |art of G|DBM, the|
|000000e0| 20 47 4e 55 20 64 61 74 | 61 20 62 61 73 65 20 6d | GNU dat|a base m|
|000000f0| 61 6e 61 67 65 72 2c 20 | 62 79 20 50 68 69 6c 69 |anager, |by Phili|
|00000100| 70 20 41 2e 20 4e 65 6c | 73 6f 6e 2e 0d 20 20 20 |p A. Nel|son.. |
|00000110| 20 43 6f 70 79 72 69 67 | 68 74 20 28 43 29 20 31 | Copyrig|ht (C) 1|
|00000120| 39 39 30 2c 20 31 39 39 | 31 20 20 46 72 65 65 20 |990, 199|1 Free |
|00000130| 53 6f 66 74 77 61 72 65 | 20 46 6f 75 6e 64 61 74 |Software| Foundat|
|00000140| 69 6f 6e 2c 20 49 6e 63 | 2e 0d 0d 20 20 20 20 47 |ion, Inc|... G|
|00000150| 44 42 4d 20 69 73 20 66 | 72 65 65 20 73 6f 66 74 |DBM is f|ree soft|
|00000160| 77 61 72 65 3b 20 79 6f | 75 20 63 61 6e 20 72 65 |ware; yo|u can re|
|00000170| 64 69 73 74 72 69 62 75 | 74 65 20 69 74 20 61 6e |distribu|te it an|
|00000180| 64 2f 6f 72 20 6d 6f 64 | 69 66 79 0d 20 20 20 20 |d/or mod|ify. |
|00000190| 69 74 20 75 6e 64 65 72 | 20 74 68 65 20 74 65 72 |it under| the ter|
|000001a0| 6d 73 20 6f 66 20 74 68 | 65 20 47 4e 55 20 47 65 |ms of th|e GNU Ge|
|000001b0| 6e 65 72 61 6c 20 50 75 | 62 6c 69 63 20 4c 69 63 |neral Pu|blic Lic|
|000001c0| 65 6e 73 65 20 61 73 20 | 70 75 62 6c 69 73 68 65 |ense as |publishe|
|000001d0| 64 20 62 79 0d 20 20 20 | 20 74 68 65 20 46 72 65 |d by. | the Fre|
|000001e0| 65 20 53 6f 66 74 77 61 | 72 65 20 46 6f 75 6e 64 |e Softwa|re Found|
|000001f0| 61 74 69 6f 6e 3b 20 65 | 69 74 68 65 72 20 76 65 |ation; e|ither ve|
|00000200| 72 73 69 6f 6e 20 31 2c | 20 6f 72 20 28 61 74 20 |rsion 1,| or (at |
|00000210| 79 6f 75 72 20 6f 70 74 | 69 6f 6e 29 0d 20 20 20 |your opt|ion). |
|00000220| 20 61 6e 79 20 6c 61 74 | 65 72 20 76 65 72 73 69 | any lat|er versi|
|00000230| 6f 6e 2e 0d 0d 20 20 20 | 20 47 44 42 4d 20 69 73 |on... | GDBM is|
|00000240| 20 64 69 73 74 72 69 62 | 75 74 65 64 20 69 6e 20 | distrib|uted in |
|00000250| 74 68 65 20 68 6f 70 65 | 20 74 68 61 74 20 69 74 |the hope| that it|
|00000260| 20 77 69 6c 6c 20 62 65 | 20 75 73 65 66 75 6c 2c | will be| useful,|
|00000270| 0d 20 20 20 20 62 75 74 | 20 57 49 54 48 4f 55 54 |. but| WITHOUT|
|00000280| 20 41 4e 59 20 57 41 52 | 52 41 4e 54 59 3b 20 77 | ANY WAR|RANTY; w|
|00000290| 69 74 68 6f 75 74 20 65 | 76 65 6e 20 74 68 65 20 |ithout e|ven the |
|000002a0| 69 6d 70 6c 69 65 64 20 | 77 61 72 72 61 6e 74 79 |implied |warranty|
|000002b0| 20 6f 66 0d 20 20 20 20 | 4d 45 52 43 48 41 4e 54 | of. |MERCHANT|
|000002c0| 41 42 49 4c 49 54 59 20 | 6f 72 20 46 49 54 4e 45 |ABILITY |or FITNE|
|000002d0| 53 53 20 46 4f 52 20 41 | 20 50 41 52 54 49 43 55 |SS FOR A| PARTICU|
|000002e0| 4c 41 52 20 50 55 52 50 | 4f 53 45 2e 20 20 53 65 |LAR PURP|OSE. Se|
|000002f0| 65 20 74 68 65 0d 20 20 | 20 20 47 4e 55 20 47 65 |e the. | GNU Ge|
|00000300| 6e 65 72 61 6c 20 50 75 | 62 6c 69 63 20 4c 69 63 |neral Pu|blic Lic|
|00000310| 65 6e 73 65 20 66 6f 72 | 20 6d 6f 72 65 20 64 65 |ense for| more de|
|00000320| 74 61 69 6c 73 2e 0d 0d | 20 20 20 20 59 6f 75 20 |tails...| You |
|00000330| 73 68 6f 75 6c 64 20 68 | 61 76 65 20 72 65 63 65 |should h|ave rece|
|00000340| 69 76 65 64 20 61 20 63 | 6f 70 79 20 6f 66 20 74 |ived a c|opy of t|
|00000350| 68 65 20 47 4e 55 20 47 | 65 6e 65 72 61 6c 20 50 |he GNU G|eneral P|
|00000360| 75 62 6c 69 63 20 4c 69 | 63 65 6e 73 65 0d 20 20 |ublic Li|cense. |
|00000370| 20 20 61 6c 6f 6e 67 20 | 77 69 74 68 20 47 44 42 | along |with GDB|
|00000380| 4d 3b 20 73 65 65 20 74 | 68 65 20 66 69 6c 65 20 |M; see t|he file |
|00000390| 43 4f 50 59 49 4e 47 2e | 20 20 49 66 20 6e 6f 74 |COPYING.| If not|
|000003a0| 2c 20 77 72 69 74 65 20 | 74 6f 0d 20 20 20 20 74 |, write |to. t|
|000003b0| 68 65 20 46 72 65 65 20 | 53 6f 66 74 77 61 72 65 |he Free |Software|
|000003c0| 20 46 6f 75 6e 64 61 74 | 69 6f 6e 2c 20 36 37 35 | Foundat|ion, 675|
|000003d0| 20 4d 61 73 73 20 41 76 | 65 2c 20 43 61 6d 62 72 | Mass Av|e, Cambr|
|000003e0| 69 64 67 65 2c 20 4d 41 | 20 30 32 31 33 39 2c 20 |idge, MA| 02139, |
|000003f0| 55 53 41 2e 0d 0d 20 20 | 20 20 59 6f 75 20 6d 61 |USA... | You ma|
|00000400| 79 20 63 6f 6e 74 61 63 | 74 20 74 68 65 20 61 75 |y contac|t the au|
|00000410| 74 68 6f 72 20 62 79 3a | 0d 20 20 20 20 20 20 20 |thor by:|. |
|00000420| 65 2d 6d 61 69 6c 3a 20 | 20 70 68 69 6c 40 63 73 |e-mail: | phil@cs|
|00000430| 2e 77 77 75 2e 65 64 75 | 0d 20 20 20 20 20 20 75 |.wwu.edu|. u|
|00000440| 73 2d 6d 61 69 6c 3a 20 | 20 50 68 69 6c 69 70 20 |s-mail: | Philip |
|00000450| 41 2e 20 4e 65 6c 73 6f | 6e 0d 20 20 20 20 20 20 |A. Nelso|n. |
|00000460| 20 20 20 20 20 20 20 20 | 20 20 43 6f 6d 70 75 74 | | Comput|
|00000470| 65 72 20 53 63 69 65 6e | 63 65 20 44 65 70 61 72 |er Scien|ce Depar|
|00000480| 74 6d 65 6e 74 0d 20 20 | 20 20 20 20 20 20 20 20 |tment. | |
|00000490| 20 20 20 20 20 20 57 65 | 73 74 65 72 6e 20 57 61 | We|stern Wa|
|000004a0| 73 68 69 6e 67 74 6f 6e | 20 55 6e 69 76 65 72 73 |shington| Univers|
|000004b0| 69 74 79 0d 20 20 20 20 | 20 20 20 20 20 20 20 20 |ity. | |
|000004c0| 20 20 20 20 42 65 6c 6c | 69 6e 67 68 61 6d 2c 20 | Bell|ingham, |
|000004d0| 57 41 20 39 38 32 32 36 | 0d 20 20 20 20 20 20 20 |WA 98226|. |
|000004e0| 20 70 68 6f 6e 65 3a 20 | 20 28 32 30 36 29 20 36 | phone: | (206) 6|
|000004f0| 37 36 2d 33 30 33 35 0d | 20 20 20 20 20 20 20 0d |76-3035.| .|
|00000500| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000510| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000520| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000530| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000540| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2f 0d 0d 0d 23 69 6e |********|*/...#in|
|00000550| 63 6c 75 64 65 20 22 67 | 64 62 6d 64 65 66 73 2e |clude "g|dbmdefs.|
|00000560| 68 22 0d 0d 0d 2f 2a 20 | 49 6e 69 74 69 61 6c 69 |h".../* |Initiali|
|00000570| 7a 69 6e 67 20 61 20 6e | 65 77 20 68 61 73 68 20 |zing a n|ew hash |
|00000580| 62 75 63 6b 65 74 73 20 | 73 65 74 73 20 61 6c 6c |buckets |sets all|
|00000590| 20 62 75 63 6b 65 74 20 | 65 6e 74 72 69 65 73 20 | bucket |entries |
|000005a0| 74 6f 20 2d 31 20 68 61 | 73 68 20 76 61 6c 75 65 |to -1 ha|sh value|
|000005b0| 2e 20 2a 2f 0d 76 6f 69 | 64 0d 5f 67 64 62 6d 5f |. */.voi|d._gdbm_|
|000005c0| 6e 65 77 5f 62 75 63 6b | 65 74 20 28 64 62 66 2c |new_buck|et (dbf,|
|000005d0| 20 62 75 63 6b 65 74 2c | 20 62 69 74 73 29 0d 20 | bucket,| bits). |
|000005e0| 20 20 20 20 67 64 62 6d | 5f 66 69 6c 65 5f 69 6e | gdbm|_file_in|
|000005f0| 66 6f 20 2a 64 62 66 3b | 0d 20 20 20 20 20 68 61 |fo *dbf;|. ha|
|00000600| 73 68 5f 62 75 63 6b 65 | 74 20 2a 62 75 63 6b 65 |sh_bucke|t *bucke|
|00000610| 74 3b 0d 20 20 20 20 20 | 69 6e 74 20 62 69 74 73 |t;. |int bits|
|00000620| 3b 0d 7b 0d 20 20 69 6e | 74 20 69 6e 64 65 78 3b |;.{. in|t index;|
|00000630| 0d 20 20 0d 20 20 2f 2a | 20 49 6e 69 74 69 61 6c |. . /*| Initial|
|00000640| 69 7a 65 20 74 68 65 20 | 61 76 61 69 6c 20 62 6c |ize the |avail bl|
|00000650| 6f 63 6b 2e 20 2a 2f 0d | 20 20 62 75 63 6b 65 74 |ock. */.| bucket|
|00000660| 2d 3e 61 76 5f 63 6f 75 | 6e 74 20 3d 20 30 3b 0d |->av_cou|nt = 0;.|
|00000670| 0d 20 20 2f 2a 20 53 65 | 74 20 74 68 65 20 69 6e |. /* Se|t the in|
|00000680| 66 6f 72 6d 61 74 69 6f | 6e 20 66 69 65 6c 64 73 |formatio|n fields|
|00000690| 20 66 69 72 73 74 2e 20 | 2a 2f 0d 20 20 62 75 63 | first. |*/. buc|
|000006a0| 6b 65 74 2d 3e 62 75 63 | 6b 65 74 5f 62 69 74 73 |ket->buc|ket_bits|
|000006b0| 20 3d 20 62 69 74 73 3b | 0d 20 20 62 75 63 6b 65 | = bits;|. bucke|
|000006c0| 74 2d 3e 63 6f 75 6e 74 | 20 3d 20 30 3b 0d 20 20 |t->count| = 0;. |
|000006d0| 0d 20 20 2f 2a 20 49 6e | 69 74 69 61 6c 69 7a 65 |. /* In|itialize|
|000006e0| 20 61 6c 6c 20 62 75 63 | 6b 65 74 20 65 6c 65 6d | all buc|ket elem|
|000006f0| 65 6e 74 73 2e 20 2a 2f | 0d 20 20 66 6f 72 20 28 |ents. */|. for (|
|00000700| 69 6e 64 65 78 20 3d 20 | 30 3b 20 69 6e 64 65 78 |index = |0; index|
|00000710| 20 3c 20 64 62 66 2d 3e | 68 65 61 64 65 72 2d 3e | < dbf->|header->|
|00000720| 62 75 63 6b 65 74 5f 65 | 6c 65 6d 73 3b 20 69 6e |bucket_e|lems; in|
|00000730| 64 65 78 2b 2b 29 0d 20 | 20 20 20 62 75 63 6b 65 |dex++). | bucke|
|00000740| 74 2d 3e 68 5f 74 61 62 | 6c 65 5b 69 6e 64 65 78 |t->h_tab|le[index|
|00000750| 5d 2e 68 61 73 68 5f 76 | 61 6c 75 65 20 3d 20 2d |].hash_v|alue = -|
|00000760| 31 3b 0d 7d 0d 0d 0d 0d | 2f 2a 20 46 69 6e 64 20 |1;.}....|/* Find |
|00000770| 61 20 62 75 63 6b 65 74 | 20 66 6f 72 20 44 42 46 |a bucket| for DBF|
|00000780| 20 74 68 61 74 20 69 73 | 20 70 6f 69 6e 74 65 64 | that is| pointed|
|00000790| 20 74 6f 20 62 79 20 74 | 68 65 20 62 75 63 6b 65 | to by t|he bucke|
|000007a0| 74 20 64 69 72 65 63 74 | 6f 72 79 20 66 72 6f 6d |t direct|ory from|
|000007b0| 0d 20 20 20 6c 6f 63 61 | 74 69 6f 6e 20 44 49 52 |. loca|tion DIR|
|000007c0| 5f 49 4e 44 45 58 2e 20 | 20 20 54 68 65 20 62 75 |_INDEX. | The bu|
|000007d0| 63 6b 65 74 20 63 61 63 | 68 65 20 69 73 20 66 69 |cket cac|he is fi|
|000007e0| 72 73 74 20 63 68 65 63 | 6b 65 64 20 74 6f 20 73 |rst chec|ked to s|
|000007f0| 65 65 20 69 66 20 69 74 | 0d 20 20 20 69 73 20 61 |ee if it|. is a|
|00000800| 6c 72 65 61 64 79 20 69 | 6e 20 6d 65 6d 6f 72 79 |lready i|n memory|
|00000810| 2e 20 20 49 66 20 6e 6f | 74 2c 20 61 20 62 75 63 |. If no|t, a buc|
|00000820| 6b 65 74 20 6d 61 79 20 | 62 65 20 74 6f 73 73 65 |ket may |be tosse|
|00000830| 64 20 74 6f 20 72 65 61 | 64 20 74 68 65 20 6e 65 |d to rea|d the ne|
|00000840| 77 0d 20 20 20 62 75 63 | 6b 65 74 2e 20 20 49 6e |w. buc|ket. In|
|00000850| 20 61 6e 79 20 63 61 73 | 65 2c 20 74 68 65 20 72 | any cas|e, the r|
|00000860| 65 71 75 65 73 74 65 64 | 20 62 75 63 6b 65 74 20 |equested| bucket |
|00000870| 69 73 20 6d 61 6b 65 20 | 74 68 65 20 22 63 75 72 |is make |the "cur|
|00000880| 72 65 6e 74 22 20 62 75 | 63 6b 65 74 0d 20 20 20 |rent" bu|cket. |
|00000890| 61 6e 64 20 64 62 66 2d | 3e 62 75 63 6b 65 74 20 |and dbf-|>bucket |
|000008a0| 70 6f 69 6e 74 73 20 74 | 6f 20 74 68 65 20 63 6f |points t|o the co|
|000008b0| 72 72 65 63 74 20 62 75 | 63 6b 65 74 2e 20 2a 2f |rrect bu|cket. */|
|000008c0| 0d 69 6e 74 0d 5f 67 64 | 62 6d 5f 67 65 74 5f 62 |.int._gd|bm_get_b|
|000008d0| 75 63 6b 65 74 20 28 64 | 62 66 2c 20 64 69 72 5f |ucket (d|bf, dir_|
|000008e0| 69 6e 64 65 78 29 0d 20 | 20 20 20 20 67 64 62 6d |index). | gdbm|
|000008f0| 5f 66 69 6c 65 5f 69 6e | 66 6f 20 2a 64 62 66 3b |_file_in|fo *dbf;|
|00000900| 0d 20 20 20 20 20 6c 6f | 6e 67 20 64 69 72 5f 69 |. lo|ng dir_i|
|00000910| 6e 64 65 78 3b 0d 7b 0d | 20 20 6c 6f 6e 67 20 20 |ndex;.{.| long |
|00000920| 62 75 63 6b 65 74 5f 61 | 64 72 3b 09 2f 2a 20 54 |bucket_a|dr;./* T|
|00000930| 68 65 20 61 64 64 72 65 | 73 73 20 6f 66 20 74 68 |he addre|ss of th|
|00000940| 65 20 63 6f 72 72 65 63 | 74 20 68 61 73 68 20 62 |e correc|t hash b|
|00000950| 75 63 6b 65 74 2e 20 20 | 2a 2f 0d 20 20 69 6e 74 |ucket. |*/. int|
|00000960| 20 20 20 6e 75 6d 5f 62 | 79 74 65 73 3b 09 2f 2a | num_b|ytes;./*|
|00000970| 20 54 68 65 20 6e 75 6d | 62 65 72 20 6f 66 20 62 | The num|ber of b|
|00000980| 79 74 65 73 20 72 65 61 | 64 2e 20 2a 2f 0d 20 20 |ytes rea|d. */. |
|00000990| 6c 6f 6e 67 20 20 66 69 | 6c 65 5f 70 6f 73 3b 09 |long fi|le_pos;.|
|000009a0| 2f 2a 20 54 68 65 20 72 | 65 74 75 72 6e 20 61 64 |/* The r|eturn ad|
|000009b0| 64 72 65 73 73 20 66 6f | 72 20 6c 73 65 65 6b 2e |dress fo|r lseek.|
|000009c0| 20 2a 2f 0d 20 20 69 6e | 74 20 20 20 69 6e 64 65 | */. in|t inde|
|000009d0| 78 3b 09 09 2f 2a 20 4c | 6f 6f 70 20 69 6e 64 65 |x;../* L|oop inde|
|000009e0| 78 2e 20 2a 2f 0d 0d 20 | 20 2f 2a 20 49 6e 69 74 |x. */.. | /* Init|
|000009f0| 69 61 6c 20 73 65 74 20 | 75 70 2e 20 2a 2f 0d 20 |ial set |up. */. |
|00000a00| 20 64 62 66 2d 3e 62 75 | 63 6b 65 74 5f 64 69 72 | dbf->bu|cket_dir|
|00000a10| 20 3d 20 64 69 72 5f 69 | 6e 64 65 78 3b 0d 20 20 | = dir_i|ndex;. |
|00000a20| 62 75 63 6b 65 74 5f 61 | 64 72 20 3d 20 64 62 66 |bucket_a|dr = dbf|
|00000a30| 2d 3e 64 69 72 20 5b 64 | 69 72 5f 69 6e 64 65 78 |->dir [d|ir_index|
|00000a40| 5d 3b 0d 20 20 0d 20 20 | 2f 2a 20 49 73 20 74 68 |];. . |/* Is th|
|00000a50| 61 74 20 6f 6e 65 20 69 | 73 20 6e 6f 74 20 61 6c |at one i|s not al|
|00000a60| 72 65 61 64 20 63 75 72 | 72 65 6e 74 2c 20 77 65 |read cur|rent, we|
|00000a70| 20 6d 75 73 74 20 66 69 | 6e 64 20 69 74 2e 20 2a | must fi|nd it. *|
|00000a80| 2f 0d 20 20 69 66 20 28 | 64 62 66 2d 3e 63 61 63 |/. if (|dbf->cac|
|00000a90| 68 65 5f 65 6e 74 72 79 | 2d 3e 63 61 5f 61 64 72 |he_entry|->ca_adr|
|00000aa0| 20 21 3d 20 62 75 63 6b | 65 74 5f 61 64 72 29 0d | != buck|et_adr).|
|00000ab0| 20 20 20 20 7b 0d 20 20 | 20 20 20 20 2f 2a 20 4c | {. | /* L|
|00000ac0| 6f 6f 6b 20 69 6e 20 74 | 68 65 20 63 61 63 68 65 |ook in t|he cache|
|00000ad0| 2e 20 2a 2f 0d 20 20 20 | 20 20 20 66 6f 72 20 28 |. */. | for (|
|00000ae0| 69 6e 64 65 78 20 3d 20 | 30 3b 20 69 6e 64 65 78 |index = |0; index|
|00000af0| 20 3c 20 43 41 43 48 45 | 5f 53 49 5a 45 3b 20 69 | < CACHE|_SIZE; i|
|00000b00| 6e 64 65 78 2b 2b 29 0d | 09 69 66 20 28 64 62 66 |ndex++).|.if (dbf|
|00000b10| 2d 3e 62 75 63 6b 65 74 | 5f 63 61 63 68 65 5b 69 |->bucket|_cache[i|
|00000b20| 6e 64 65 78 5d 2e 63 61 | 5f 61 64 72 20 3d 3d 20 |ndex].ca|_adr == |
|00000b30| 62 75 63 6b 65 74 5f 61 | 64 72 29 0d 09 20 20 7b |bucket_a|dr).. {|
|00000b40| 0d 09 20 20 20 20 64 62 | 66 2d 3e 62 75 63 6b 65 |.. db|f->bucke|
|00000b50| 74 20 3d 20 64 62 66 2d | 3e 62 75 63 6b 65 74 5f |t = dbf-|>bucket_|
|00000b60| 63 61 63 68 65 5b 69 6e | 64 65 78 5d 2e 63 61 5f |cache[in|dex].ca_|
|00000b70| 62 75 63 6b 65 74 3b 0d | 09 20 20 20 20 64 62 66 |bucket;.|. dbf|
|00000b80| 2d 3e 63 61 63 68 65 5f | 65 6e 74 72 79 20 3d 20 |->cache_|entry = |
|00000b90| 26 64 62 66 2d 3e 62 75 | 63 6b 65 74 5f 63 61 63 |&dbf->bu|cket_cac|
|00000ba0| 68 65 5b 69 6e 64 65 78 | 5d 3b 0d 09 20 20 20 20 |he[index|];.. |
|00000bb0| 72 65 74 75 72 6e 20 30 | 3b 0d 09 20 20 7d 0d 0d |return 0|;.. }..|
|00000bc0| 20 20 20 20 20 20 2f 2a | 20 49 74 20 69 73 20 6e | /*| It is n|
|00000bd0| 6f 74 20 69 6e 20 74 68 | 65 20 63 61 63 68 65 2c |ot in th|e cache,|
|00000be0| 20 72 65 61 64 20 69 74 | 20 66 72 6f 6d 20 74 68 | read it| from th|
|00000bf0| 65 20 64 69 73 6b 2e 20 | 2a 2f 0d 20 20 20 20 20 |e disk. |*/. |
|00000c00| 20 64 62 66 2d 3e 6c 61 | 73 74 5f 72 65 61 64 20 | dbf->la|st_read |
|00000c10| 3d 20 28 64 62 66 2d 3e | 6c 61 73 74 5f 72 65 61 |= (dbf->|last_rea|
|00000c20| 64 20 2b 20 31 29 20 25 | 20 43 41 43 48 45 5f 53 |d + 1) %| CACHE_S|
|00000c30| 49 5a 45 3b 0d 20 20 20 | 20 20 20 64 62 66 2d 3e |IZE;. | dbf->|
|00000c40| 62 75 63 6b 65 74 5f 63 | 61 63 68 65 5b 64 62 66 |bucket_c|ache[dbf|
|00000c50| 2d 3e 6c 61 73 74 5f 72 | 65 61 64 5d 2e 63 61 5f |->last_r|ead].ca_|
|00000c60| 61 64 72 20 3d 20 62 75 | 63 6b 65 74 5f 61 64 72 |adr = bu|cket_adr|
|00000c70| 3b 0d 20 20 20 20 20 20 | 64 62 66 2d 3e 62 75 63 |;. |dbf->buc|
|00000c80| 6b 65 74 20 3d 20 64 62 | 66 2d 3e 62 75 63 6b 65 |ket = db|f->bucke|
|00000c90| 74 5f 63 61 63 68 65 5b | 64 62 66 2d 3e 6c 61 73 |t_cache[|dbf->las|
|00000ca0| 74 5f 72 65 61 64 5d 2e | 63 61 5f 62 75 63 6b 65 |t_read].|ca_bucke|
|00000cb0| 74 3b 0d 20 20 20 20 20 | 20 64 62 66 2d 3e 63 61 |t;. | dbf->ca|
|00000cc0| 63 68 65 5f 65 6e 74 72 | 79 20 3d 20 26 64 62 66 |che_entr|y = &dbf|
|00000cd0| 2d 3e 62 75 63 6b 65 74 | 5f 63 61 63 68 65 5b 64 |->bucket|_cache[d|
|00000ce0| 62 66 2d 3e 6c 61 73 74 | 5f 72 65 61 64 5d 3b 0d |bf->last|_read];.|
|00000cf0| 20 20 20 20 20 20 64 62 | 66 2d 3e 63 61 63 68 65 | db|f->cache|
|00000d00| 5f 65 6e 74 72 79 2d 3e | 63 61 5f 64 61 74 61 2e |_entry->|ca_data.|
|00000d10| 65 6c 65 6d 5f 6c 6f 63 | 20 3d 20 2d 31 3b 0d 20 |elem_loc| = -1;. |
|00000d20| 20 20 20 20 20 64 62 66 | 2d 3e 63 61 63 68 65 5f | dbf|->cache_|
|00000d30| 65 6e 74 72 79 2d 3e 63 | 61 5f 63 68 61 6e 67 65 |entry->c|a_change|
|00000d40| 64 20 3d 20 46 41 4c 53 | 45 3b 0d 0d 20 20 20 20 |d = FALS|E;.. |
|00000d50| 20 20 2f 2a 20 52 65 61 | 64 20 74 68 65 20 62 75 | /* Rea|d the bu|
|00000d60| 63 6b 65 74 2e 20 2a 2f | 0d 20 20 20 20 20 20 66 |cket. */|. f|
|00000d70| 69 6c 65 5f 70 6f 73 20 | 3d 20 6c 73 65 65 6b 20 |ile_pos |= lseek |
|00000d80| 28 64 62 66 2d 3e 64 65 | 73 63 2c 20 62 75 63 6b |(dbf->de|sc, buck|
|00000d90| 65 74 5f 61 64 72 2c 20 | 4c 5f 53 45 54 29 3b 0d |et_adr, |L_SET);.|
|00000da0| 20 20 20 20 20 20 69 66 | 20 28 66 69 6c 65 5f 70 | if| (file_p|
|00000db0| 6f 73 20 21 3d 20 62 75 | 63 6b 65 74 5f 61 64 72 |os != bu|cket_adr|
|00000dc0| 29 0d 09 5f 67 64 62 6d | 5f 66 61 74 61 6c 20 28 |).._gdbm|_fatal (|
|00000dd0| 64 62 66 2c 20 22 6c 73 | 65 65 6b 20 65 72 72 6f |dbf, "ls|eek erro|
|00000de0| 72 22 29 3b 0d 0d 20 20 | 20 20 20 20 6e 75 6d 5f |r");.. | num_|
|00000df0| 62 79 74 65 73 20 3d 20 | 72 65 61 64 20 28 64 62 |bytes = |read (db|
|00000e00| 66 2d 3e 64 65 73 63 2c | 20 28 63 68 61 72 20 2a |f->desc,| (char *|
|00000e10| 29 20 64 62 66 2d 3e 62 | 75 63 6b 65 74 2c 20 64 |) dbf->b|ucket, d|
|00000e20| 62 66 2d 3e 68 65 61 64 | 65 72 2d 3e 62 75 63 6b |bf->head|er->buck|
|00000e30| 65 74 5f 73 69 7a 65 29 | 3b 0d 20 20 20 20 20 20 |et_size)|;. |
|00000e40| 69 66 20 28 6e 75 6d 5f | 62 79 74 65 73 20 21 3d |if (num_|bytes !=|
|00000e50| 20 64 62 66 2d 3e 68 65 | 61 64 65 72 2d 3e 62 75 | dbf->he|ader->bu|
|00000e60| 63 6b 65 74 5f 73 69 7a | 65 29 0d 09 5f 67 64 62 |cket_siz|e).._gdb|
|00000e70| 6d 5f 66 61 74 61 6c 20 | 28 64 62 66 2c 20 22 72 |m_fatal |(dbf, "r|
|00000e80| 65 61 64 20 65 72 72 6f | 72 22 29 3b 0d 20 20 20 |ead erro|r");. |
|00000e90| 20 7d 0d 0d 20 20 72 65 | 74 75 72 6e 20 30 3b 0d | }.. re|turn 0;.|
|00000ea0| 7d 0d 0d 0d 2f 2a 20 53 | 70 6c 69 74 20 74 68 65 |}.../* S|plit the|
|00000eb0| 20 63 75 72 72 65 6e 74 | 20 62 75 63 6b 65 74 2e | current| bucket.|
|00000ec0| 20 20 54 68 69 73 20 69 | 6e 63 6c 75 64 65 73 20 | This i|ncludes |
|00000ed0| 6d 6f 76 69 6e 67 20 61 | 6c 6c 20 69 74 65 6d 73 |moving a|ll items|
|00000ee0| 20 69 6e 20 74 68 65 20 | 62 75 63 6b 65 74 20 74 | in the |bucket t|
|00000ef0| 6f 0d 20 20 20 61 20 6e | 65 77 20 62 75 63 6b 65 |o. a n|ew bucke|
|00000f00| 74 2e 20 20 54 68 69 73 | 20 64 6f 65 73 6e 27 74 |t. This| doesn't|
|00000f10| 20 72 65 71 75 69 72 65 | 20 61 6e 79 20 64 69 73 | require| any dis|
|00000f20| 6b 20 72 65 61 64 73 20 | 62 65 63 61 75 73 65 20 |k reads |because |
|00000f30| 61 6c 6c 20 68 61 73 68 | 20 76 61 6c 75 65 73 0d |all hash| values.|
|00000f40| 20 20 20 61 72 65 20 73 | 74 6f 72 65 64 20 69 6e | are s|tored in|
|00000f50| 20 74 68 65 20 62 75 63 | 6b 65 74 73 2e 20 20 53 | the buc|kets. S|
|00000f60| 70 6c 69 74 74 69 6e 67 | 20 74 68 65 20 63 75 72 |plitting| the cur|
|00000f70| 72 65 6e 74 20 62 75 63 | 6b 65 74 20 6d 61 79 20 |rent buc|ket may |
|00000f80| 72 65 71 75 69 72 65 0d | 20 20 20 64 6f 75 62 6c |require.| doubl|
|00000f90| 69 6e 67 20 74 68 65 20 | 73 69 7a 65 20 6f 66 20 |ing the |size of |
|00000fa0| 74 68 65 20 68 61 73 68 | 20 64 69 72 65 63 74 6f |the hash| directo|
|00000fb0| 72 79 2e 20 20 2a 2f 0d | 76 6f 69 64 0d 5f 67 64 |ry. */.|void._gd|
|00000fc0| 62 6d 5f 73 70 6c 69 74 | 5f 62 75 63 6b 65 74 20 |bm_split|_bucket |
|00000fd0| 28 64 62 66 2c 20 6e 65 | 78 74 5f 69 6e 73 65 72 |(dbf, ne|xt_inser|
|00000fe0| 74 29 0d 20 20 20 20 20 | 67 64 62 6d 5f 66 69 6c |t). |gdbm_fil|
|00000ff0| 65 5f 69 6e 66 6f 20 2a | 64 62 66 3b 0d 20 20 20 |e_info *|dbf;. |
|00001000| 20 20 69 6e 74 20 6e 65 | 78 74 5f 69 6e 73 65 72 | int ne|xt_inser|
|00001010| 74 3b 0d 7b 0d 20 20 68 | 61 73 68 5f 62 75 63 6b |t;.{. h|ash_buck|
|00001020| 65 74 20 2a 62 75 63 6b | 65 74 5b 32 5d 3b 20 09 |et *buck|et[2]; .|
|00001030| 2f 2a 20 50 6f 69 6e 74 | 65 72 73 20 74 6f 20 74 |/* Point|ers to t|
|00001040| 68 65 20 6e 65 77 20 62 | 75 63 6b 65 74 73 2e 20 |he new b|uckets. |
|00001050| 2a 2f 0d 0d 20 20 69 6e | 74 20 20 20 20 20 20 20 |*/.. in|t |
|00001060| 20 20 20 6e 65 77 5f 62 | 69 74 73 3b 09 2f 2a 20 | new_b|its;./* |
|00001070| 54 68 65 20 6e 75 6d 62 | 65 72 20 6f 66 20 62 69 |The numb|er of bi|
|00001080| 74 73 20 66 6f 72 20 74 | 68 65 20 6e 65 77 20 62 |ts for t|he new b|
|00001090| 75 63 6b 65 74 73 2e 20 | 2a 2f 0d 20 20 69 6e 74 |uckets. |*/. int|
|000010a0| 09 20 20 20 20 20 20 20 | 63 61 63 68 65 5f 30 3b |. |cache_0;|
|000010b0| 09 09 2f 2a 20 4c 6f 63 | 61 74 69 6f 6e 20 69 6e |../* Loc|ation in|
|000010c0| 20 74 68 65 20 63 61 63 | 68 65 20 66 6f 72 20 74 | the cac|he for t|
|000010d0| 68 65 20 62 75 63 6b 65 | 74 73 2e 20 2a 2f 0d 20 |he bucke|ts. */. |
|000010e0| 20 69 6e 74 09 20 20 20 | 20 20 20 20 63 61 63 68 | int. | cach|
|000010f0| 65 5f 31 3b 0d 20 20 6c | 6f 6e 67 09 20 20 20 20 |e_1;. l|ong. |
|00001100| 20 20 20 61 64 72 5f 30 | 3b 09 09 2f 2a 20 46 69 | adr_0|;../* Fi|
|00001110| 6c 65 20 61 64 64 72 65 | 73 73 20 6f 66 20 74 68 |le addre|ss of th|
|00001120| 65 20 6e 65 77 20 62 75 | 63 6b 65 74 20 30 2e 20 |e new bu|cket 0. |
|00001130| 2a 2f 0d 20 20 6c 6f 6e | 67 09 20 20 20 20 20 20 |*/. lon|g. |
|00001140| 20 61 64 72 5f 31 3b 09 | 09 2f 2a 20 46 69 6c 65 | adr_1;.|./* File|
|00001150| 20 61 64 64 72 65 73 73 | 20 6f 66 20 74 68 65 20 | address| of the |
|00001160| 6e 65 77 20 62 75 63 6b | 65 74 20 31 2e 20 2a 2f |new buck|et 1. */|
|00001170| 0d 20 20 61 76 61 69 6c | 5f 65 6c 65 6d 20 20 20 |. avail|_elem |
|00001180| 6f 6c 64 5f 62 75 63 6b | 65 74 3b 09 2f 2a 20 41 |old_buck|et;./* A|
|00001190| 76 61 69 6c 20 53 74 72 | 75 63 74 20 66 6f 72 20 |vail Str|uct for |
|000011a0| 74 68 65 20 6f 6c 64 20 | 62 75 63 6b 65 74 2e 20 |the old |bucket. |
|000011b0| 2a 2f 0d 0d 20 20 6c 6f | 6e 67 20 20 20 20 20 20 |*/.. lo|ng |
|000011c0| 20 20 20 64 69 72 5f 73 | 74 61 72 74 30 3b 09 2f | dir_s|tart0;./|
|000011d0| 2a 20 55 73 65 64 20 69 | 6e 20 75 70 64 61 74 69 |* Used i|n updati|
|000011e0| 6e 67 20 74 68 65 20 64 | 69 72 65 63 74 6f 72 79 |ng the d|irectory|
|000011f0| 2e 20 2a 2f 0d 20 20 6c | 6f 6e 67 20 20 20 20 20 |. */. l|ong |
|00001200| 20 20 20 20 64 69 72 5f | 73 74 61 72 74 31 3b 0d | dir_|start1;.|
|00001210| 20 20 6c 6f 6e 67 20 20 | 20 20 20 20 20 20 20 64 | long | d|
|00001220| 69 72 5f 65 6e 64 3b 0d | 0d 20 20 6c 6f 6e 67 09 |ir_end;.|. long.|
|00001230| 20 20 20 20 20 20 2a 6e | 65 77 5f 64 69 72 3b 09 | *n|ew_dir;.|
|00001240| 09 2f 2a 20 50 6f 69 6e | 74 65 72 20 74 6f 20 74 |./* Poin|ter to t|
|00001250| 68 65 20 6e 65 77 20 64 | 69 72 65 63 74 6f 72 79 |he new d|irectory|
|00001260| 2e 20 2a 2f 0d 20 20 6c | 6f 6e 67 20 20 20 20 20 |. */. l|ong |
|00001270| 20 20 20 20 64 69 72 5f | 61 64 72 3b 20 09 2f 2a | dir_|adr; ./*|
|00001280| 20 41 64 64 72 65 73 73 | 20 6f 66 20 74 68 65 20 | Address| of the |
|00001290| 6e 65 77 20 64 69 72 65 | 63 74 6f 72 79 2e 20 2a |new dire|ctory. *|
|000012a0| 2f 0d 20 20 6c 6f 6e 67 | 20 20 20 20 20 20 20 20 |/. long| |
|000012b0| 20 64 69 72 5f 73 69 7a | 65 3b 09 2f 2a 20 53 69 | dir_siz|e;./* Si|
|000012c0| 7a 65 20 6f 66 20 74 68 | 65 20 6e 65 77 20 64 69 |ze of th|e new di|
|000012d0| 72 65 63 74 6f 72 79 2e | 20 2a 2f 0d 20 20 6c 6f |rectory.| */. lo|
|000012e0| 6e 67 20 20 20 20 20 20 | 20 20 20 6f 6c 64 5f 61 |ng | old_a|
|000012f0| 64 72 5b 33 31 5d 3b 20 | 09 2f 2a 20 41 64 64 72 |dr[31]; |./* Addr|
|00001300| 65 73 73 20 6f 66 20 74 | 68 65 20 6f 6c 64 20 64 |ess of t|he old d|
|00001310| 69 72 65 63 74 6f 72 69 | 65 73 2e 20 2a 2f 0d 20 |irectori|es. */. |
|00001320| 20 6c 6f 6e 67 20 20 20 | 20 20 20 20 20 20 6f 6c | long | ol|
|00001330| 64 5f 73 69 7a 65 5b 33 | 31 5d 3b 20 09 2f 2a 20 |d_size[3|1]; ./* |
|00001340| 53 69 7a 65 20 6f 66 20 | 74 68 65 20 6f 6c 64 20 |Size of |the old |
|00001350| 64 69 72 65 63 74 6f 72 | 69 65 73 2e 20 2a 2f 0d |director|ies. */.|
|00001360| 20 20 69 6e 74 09 20 20 | 20 20 20 20 20 6f 6c 64 | int. | old|
|00001370| 5f 63 6f 75 6e 74 3b 09 | 2f 2a 20 4e 75 6d 62 65 |_count;.|/* Numbe|
|00001380| 72 20 6f 66 20 6f 6c 64 | 20 64 69 72 65 63 74 6f |r of old| directo|
|00001390| 72 69 65 73 2e 20 2a 2f | 0d 0d 20 20 69 6e 74 20 |ries. */|.. int |
|000013a0| 20 20 20 20 20 20 20 20 | 20 69 6e 64 65 78 3b 09 | | index;.|
|000013b0| 09 2f 2a 20 55 73 65 64 | 20 69 6e 20 61 72 72 61 |./* Used| in arra|
|000013c0| 79 20 69 6e 64 65 78 69 | 6e 67 2e 20 2a 2f 0d 20 |y indexi|ng. */. |
|000013d0| 20 69 6e 74 20 20 20 20 | 20 20 20 20 20 20 69 6e | int | in|
|000013e0| 64 65 78 31 3b 09 09 2f | 2a 20 55 73 65 64 20 69 |dex1;../|* Used i|
|000013f0| 6e 20 61 72 72 61 79 20 | 69 6e 64 65 78 69 6e 67 |n array |indexing|
|00001400| 2e 20 2a 2f 0d 20 20 69 | 6e 74 20 20 20 20 20 20 |. */. i|nt |
|00001410| 20 20 20 20 65 6c 65 6d | 5f 6c 6f 63 3b 09 2f 2a | elem|_loc;./*|
|00001420| 20 4c 6f 63 61 74 69 6f | 6e 20 69 6e 20 6e 65 77 | Locatio|n in new|
|00001430| 20 62 75 63 6b 65 74 20 | 74 6f 20 70 75 74 20 65 | bucket |to put e|
|00001440| 6c 65 6d 65 6e 74 2e 20 | 2a 2f 0d 20 20 62 75 63 |lement. |*/. buc|
|00001450| 6b 65 74 5f 65 6c 65 6d | 65 6e 74 20 2a 6f 6c 64 |ket_elem|ent *old|
|00001460| 5f 65 6c 3b 09 2f 2a 20 | 50 6f 69 6e 74 65 72 20 |_el;./* |Pointer |
|00001470| 69 6e 74 6f 20 74 68 65 | 20 6f 6c 64 20 62 75 63 |into the| old buc|
|00001480| 6b 65 74 2e 20 2a 2f 0d | 20 20 69 6e 74 09 20 20 |ket. */.| int. |
|00001490| 20 20 20 20 20 73 65 6c | 65 63 74 3b 09 09 2f 2a | sel|ect;../*|
|000014a0| 20 55 73 65 64 20 74 6f | 20 69 6e 64 65 78 20 62 | Used to| index b|
|000014b0| 75 63 6b 65 74 20 64 75 | 72 69 6e 67 20 6d 6f 76 |ucket du|ring mov|
|000014c0| 65 6d 65 6e 74 2e 20 2a | 2f 0d 0d 0d 20 20 2f 2a |ement. *|/... /*|
|000014d0| 20 4e 6f 20 64 69 72 65 | 63 74 6f 72 69 65 73 20 | No dire|ctories |
|000014e0| 61 72 65 20 79 65 74 20 | 6f 6c 64 2e 20 2a 2f 0d |are yet |old. */.|
|000014f0| 20 20 6f 6c 64 5f 63 6f | 75 6e 74 20 3d 20 30 3b | old_co|unt = 0;|
|00001500| 0d 0d 20 20 77 68 69 6c | 65 20 28 64 62 66 2d 3e |.. whil|e (dbf->|
|00001510| 62 75 63 6b 65 74 2d 3e | 63 6f 75 6e 74 20 3d 3d |bucket->|count ==|
|00001520| 20 64 62 66 2d 3e 68 65 | 61 64 65 72 2d 3e 62 75 | dbf->he|ader->bu|
|00001530| 63 6b 65 74 5f 65 6c 65 | 6d 73 29 0d 20 20 20 20 |cket_ele|ms). |
|00001540| 7b 0d 20 20 20 20 20 20 | 2f 2a 20 49 6e 69 74 69 |{. |/* Initi|
|00001550| 61 6c 69 7a 65 20 74 68 | 65 20 22 6e 65 77 22 20 |alize th|e "new" |
|00001560| 62 75 63 6b 65 74 73 20 | 69 6e 20 74 68 65 20 63 |buckets |in the c|
|00001570| 61 63 68 65 2e 20 2a 2f | 0d 20 20 20 20 20 20 64 |ache. */|. d|
|00001580| 6f 0d 09 7b 0d 09 20 20 | 64 62 66 2d 3e 6c 61 73 |o..{.. |dbf->las|
|00001590| 74 5f 72 65 61 64 20 3d | 20 28 64 62 66 2d 3e 6c |t_read =| (dbf->l|
|000015a0| 61 73 74 5f 72 65 61 64 | 20 2b 20 31 29 20 25 20 |ast_read| + 1) % |
|000015b0| 43 41 43 48 45 5f 53 49 | 5a 45 3b 0d 09 20 20 63 |CACHE_SI|ZE;.. c|
|000015c0| 61 63 68 65 5f 30 20 3d | 20 64 62 66 2d 3e 6c 61 |ache_0 =| dbf->la|
|000015d0| 73 74 5f 72 65 61 64 3b | 0d 09 7d 20 20 20 20 20 |st_read;|..} |
|000015e0| 20 0d 20 20 20 20 20 20 | 77 68 69 6c 65 20 28 64 | . |while (d|
|000015f0| 62 66 2d 3e 62 75 63 6b | 65 74 5f 63 61 63 68 65 |bf->buck|et_cache|
|00001600| 5b 63 61 63 68 65 5f 30 | 5d 2e 63 61 5f 62 75 63 |[cache_0|].ca_buc|
|00001610| 6b 65 74 20 3d 3d 20 64 | 62 66 2d 3e 62 75 63 6b |ket == d|bf->buck|
|00001620| 65 74 29 3b 0d 20 20 20 | 20 20 20 62 75 63 6b 65 |et);. | bucke|
|00001630| 74 5b 30 5d 20 3d 20 64 | 62 66 2d 3e 62 75 63 6b |t[0] = d|bf->buck|
|00001640| 65 74 5f 63 61 63 68 65 | 5b 63 61 63 68 65 5f 30 |et_cache|[cache_0|
|00001650| 5d 2e 63 61 5f 62 75 63 | 6b 65 74 3b 0d 20 20 20 |].ca_buc|ket;. |
|00001660| 20 20 20 69 66 20 28 64 | 62 66 2d 3e 62 75 63 6b | if (d|bf->buck|
|00001670| 65 74 5f 63 61 63 68 65 | 5b 63 61 63 68 65 5f 30 |et_cache|[cache_0|
|00001680| 5d 2e 63 61 5f 63 68 61 | 6e 67 65 64 29 0d 09 5f |].ca_cha|nged).._|
|00001690| 67 64 62 6d 5f 77 72 69 | 74 65 5f 62 75 63 6b 65 |gdbm_wri|te_bucke|
|000016a0| 74 20 28 64 62 66 2c 20 | 26 64 62 66 2d 3e 62 75 |t (dbf, |&dbf->bu|
|000016b0| 63 6b 65 74 5f 63 61 63 | 68 65 5b 63 61 63 68 65 |cket_cac|he[cache|
|000016c0| 5f 30 5d 29 3b 0d 20 20 | 20 20 20 20 64 6f 0d 09 |_0]);. | do..|
|000016d0| 7b 0d 09 20 20 64 62 66 | 2d 3e 6c 61 73 74 5f 72 |{.. dbf|->last_r|
|000016e0| 65 61 64 20 3d 20 28 64 | 62 66 2d 3e 6c 61 73 74 |ead = (d|bf->last|
|000016f0| 5f 72 65 61 64 20 2b 20 | 31 29 20 25 20 43 41 43 |_read + |1) % CAC|
|00001700| 48 45 5f 53 49 5a 45 3b | 0d 09 20 20 63 61 63 68 |HE_SIZE;|.. cach|
|00001710| 65 5f 31 20 3d 20 64 62 | 66 2d 3e 6c 61 73 74 5f |e_1 = db|f->last_|
|00001720| 72 65 61 64 3b 0d 09 7d | 20 20 20 20 20 20 0d 20 |read;..}| . |
|00001730| 20 20 20 20 20 77 68 69 | 6c 65 20 28 64 62 66 2d | whi|le (dbf-|
|00001740| 3e 62 75 63 6b 65 74 5f | 63 61 63 68 65 5b 63 61 |>bucket_|cache[ca|
|00001750| 63 68 65 5f 31 5d 2e 63 | 61 5f 62 75 63 6b 65 74 |che_1].c|a_bucket|
|00001760| 20 3d 3d 20 64 62 66 2d | 3e 62 75 63 6b 65 74 29 | == dbf-|>bucket)|
|00001770| 3b 0d 20 20 20 20 20 20 | 62 75 63 6b 65 74 5b 31 |;. |bucket[1|
|00001780| 5d 20 3d 20 64 62 66 2d | 3e 62 75 63 6b 65 74 5f |] = dbf-|>bucket_|
|00001790| 63 61 63 68 65 5b 63 61 | 63 68 65 5f 31 5d 2e 63 |cache[ca|che_1].c|
|000017a0| 61 5f 62 75 63 6b 65 74 | 3b 0d 20 20 20 20 20 20 |a_bucket|;. |
|000017b0| 69 66 20 28 64 62 66 2d | 3e 62 75 63 6b 65 74 5f |if (dbf-|>bucket_|
|000017c0| 63 61 63 68 65 5b 63 61 | 63 68 65 5f 31 5d 2e 63 |cache[ca|che_1].c|
|000017d0| 61 5f 63 68 61 6e 67 65 | 64 29 0d 09 5f 67 64 62 |a_change|d).._gdb|
|000017e0| 6d 5f 77 72 69 74 65 5f | 62 75 63 6b 65 74 20 28 |m_write_|bucket (|
|000017f0| 64 62 66 2c 20 26 64 62 | 66 2d 3e 62 75 63 6b 65 |dbf, &db|f->bucke|
|00001800| 74 5f 63 61 63 68 65 5b | 63 61 63 68 65 5f 31 5d |t_cache[|cache_1]|
|00001810| 29 3b 0d 20 20 20 20 20 | 20 6e 65 77 5f 62 69 74 |);. | new_bit|
|00001820| 73 20 3d 20 64 62 66 2d | 3e 62 75 63 6b 65 74 2d |s = dbf-|>bucket-|
|00001830| 3e 62 75 63 6b 65 74 5f | 62 69 74 73 2b 31 3b 0d |>bucket_|bits+1;.|
|00001840| 20 20 20 20 20 20 5f 67 | 64 62 6d 5f 6e 65 77 5f | _g|dbm_new_|
|00001850| 62 75 63 6b 65 74 20 28 | 64 62 66 2c 20 62 75 63 |bucket (|dbf, buc|
|00001860| 6b 65 74 5b 30 5d 2c 20 | 6e 65 77 5f 62 69 74 73 |ket[0], |new_bits|
|00001870| 29 3b 0d 20 20 20 20 20 | 20 5f 67 64 62 6d 5f 6e |);. | _gdbm_n|
|00001880| 65 77 5f 62 75 63 6b 65 | 74 20 28 64 62 66 2c 20 |ew_bucke|t (dbf, |
|00001890| 62 75 63 6b 65 74 5b 31 | 5d 2c 20 6e 65 77 5f 62 |bucket[1|], new_b|
|000018a0| 69 74 73 29 3b 0d 20 20 | 20 20 20 20 61 64 72 5f |its);. | adr_|
|000018b0| 30 20 3d 20 5f 67 64 62 | 6d 5f 61 6c 6c 6f 63 20 |0 = _gdb|m_alloc |
|000018c0| 28 64 62 66 2c 20 64 62 | 66 2d 3e 68 65 61 64 65 |(dbf, db|f->heade|
|000018d0| 72 2d 3e 62 75 63 6b 65 | 74 5f 73 69 7a 65 29 3b |r->bucke|t_size);|
|000018e0| 20 0d 20 20 20 20 20 20 | 64 62 66 2d 3e 62 75 63 | . |dbf->buc|
|000018f0| 6b 65 74 5f 63 61 63 68 | 65 5b 63 61 63 68 65 5f |ket_cach|e[cache_|
|00001900| 30 5d 2e 63 61 5f 61 64 | 72 20 3d 20 61 64 72 5f |0].ca_ad|r = adr_|
|00001910| 30 3b 0d 20 20 20 20 20 | 20 61 64 72 5f 31 20 3d |0;. | adr_1 =|
|00001920| 20 5f 67 64 62 6d 5f 61 | 6c 6c 6f 63 20 28 64 62 | _gdbm_a|lloc (db|
|00001930| 66 2c 20 64 62 66 2d 3e | 68 65 61 64 65 72 2d 3e |f, dbf->|header->|
|00001940| 62 75 63 6b 65 74 5f 73 | 69 7a 65 29 3b 0d 20 20 |bucket_s|ize);. |
|00001950| 20 20 20 20 64 62 66 2d | 3e 62 75 63 6b 65 74 5f | dbf-|>bucket_|
|00001960| 63 61 63 68 65 5b 63 61 | 63 68 65 5f 31 5d 2e 63 |cache[ca|che_1].c|
|00001970| 61 5f 61 64 72 20 3d 20 | 61 64 72 5f 31 3b 0d 0d |a_adr = |adr_1;..|
|00001980| 20 20 20 20 20 20 0d 20 | 20 20 20 20 20 0d 20 20 | . | . |
|00001990| 20 20 20 20 2f 2a 20 44 | 6f 75 62 6c 65 20 74 68 | /* D|ouble th|
|000019a0| 65 20 64 69 72 65 63 74 | 6f 72 79 20 73 69 7a 65 |e direct|ory size|
|000019b0| 20 69 66 20 6e 65 63 65 | 73 73 61 72 79 2e 20 2a | if nece|ssary. *|
|000019c0| 2f 0d 20 20 20 20 20 20 | 69 66 20 28 64 62 66 2d |/. |if (dbf-|
|000019d0| 3e 68 65 61 64 65 72 2d | 3e 64 69 72 5f 62 69 74 |>header-|>dir_bit|
|000019e0| 73 20 3d 3d 20 64 62 66 | 2d 3e 62 75 63 6b 65 74 |s == dbf|->bucket|
|000019f0| 2d 3e 62 75 63 6b 65 74 | 5f 62 69 74 73 29 0d 09 |->bucket|_bits)..|
|00001a00| 7b 0d 09 20 20 64 69 72 | 5f 73 69 7a 65 20 3d 20 |{.. dir|_size = |
|00001a10| 64 62 66 2d 3e 68 65 61 | 64 65 72 2d 3e 64 69 72 |dbf->hea|der->dir|
|00001a20| 5f 73 69 7a 65 20 2a 20 | 32 3b 0d 09 20 20 64 69 |_size * |2;.. di|
|00001a30| 72 5f 61 64 72 20 20 3d | 20 5f 67 64 62 6d 5f 61 |r_adr =| _gdbm_a|
|00001a40| 6c 6c 6f 63 20 28 64 62 | 66 2c 20 64 69 72 5f 73 |lloc (db|f, dir_s|
|00001a50| 69 7a 65 29 3b 0d 09 20 | 20 6e 65 77 5f 64 69 72 |ize);.. | new_dir|
|00001a60| 20 20 3d 20 28 6c 6f 6e | 67 20 2a 29 20 6d 61 6c | = (lon|g *) mal|
|00001a70| 6c 6f 63 20 28 64 69 72 | 5f 73 69 7a 65 29 3b 0d |loc (dir|_size);.|
|00001a80| 09 20 20 69 66 20 28 6e | 65 77 5f 64 69 72 20 3d |. if (n|ew_dir =|
|00001a90| 3d 20 4e 55 4c 4c 29 20 | 5f 67 64 62 6d 5f 66 61 |= NULL) |_gdbm_fa|
|00001aa0| 74 61 6c 20 28 64 62 66 | 2c 20 22 6d 61 6c 6c 6f |tal (dbf|, "mallo|
|00001ab0| 63 20 65 72 72 6f 72 22 | 29 3b 0d 09 20 20 66 6f |c error"|);.. fo|
|00001ac0| 72 20 28 69 6e 64 65 78 | 20 3d 20 30 3b 20 69 6e |r (index| = 0; in|
|00001ad0| 64 65 78 20 3c 20 64 62 | 66 2d 3e 68 65 61 64 65 |dex < db|f->heade|
|00001ae0| 72 2d 3e 64 69 72 5f 73 | 69 7a 65 2f 73 69 7a 65 |r->dir_s|ize/size|
|00001af0| 6f 66 20 28 69 6e 74 29 | 3b 20 69 6e 64 65 78 2b |of (int)|; index+|
|00001b00| 2b 29 0d 09 20 20 20 20 | 7b 0d 09 20 20 20 20 20 |+).. |{.. |
|00001b10| 20 6e 65 77 5f 64 69 72 | 5b 32 2a 69 6e 64 65 78 | new_dir|[2*index|
|00001b20| 5d 20 20 20 3d 20 64 62 | 66 2d 3e 64 69 72 5b 69 |] = db|f->dir[i|
|00001b30| 6e 64 65 78 5d 3b 0d 09 | 20 20 20 20 20 20 6e 65 |ndex];..| ne|
|00001b40| 77 5f 64 69 72 5b 32 2a | 69 6e 64 65 78 2b 31 5d |w_dir[2*|index+1]|
|00001b50| 20 3d 20 64 62 66 2d 3e | 64 69 72 5b 69 6e 64 65 | = dbf->|dir[inde|
|00001b60| 78 5d 3b 0d 09 20 20 20 | 20 7d 0d 09 20 20 0d 09 |x];.. | }.. ..|
|00001b70| 20 20 2f 2a 20 55 70 64 | 61 74 65 20 68 65 61 64 | /* Upd|ate head|
|00001b80| 65 72 2e 20 2a 2f 0d 09 | 20 20 6f 6c 64 5f 61 64 |er. */..| old_ad|
|00001b90| 72 5b 6f 6c 64 5f 63 6f | 75 6e 74 5d 20 3d 20 64 |r[old_co|unt] = d|
|00001ba0| 62 66 2d 3e 68 65 61 64 | 65 72 2d 3e 64 69 72 3b |bf->head|er->dir;|
|00001bb0| 0d 09 20 20 64 62 66 2d | 3e 68 65 61 64 65 72 2d |.. dbf-|>header-|
|00001bc0| 3e 64 69 72 20 3d 20 64 | 69 72 5f 61 64 72 3b 0d |>dir = d|ir_adr;.|
|00001bd0| 09 20 20 6f 6c 64 5f 73 | 69 7a 65 5b 6f 6c 64 5f |. old_s|ize[old_|
|00001be0| 63 6f 75 6e 74 5d 20 3d | 20 64 62 66 2d 3e 68 65 |count] =| dbf->he|
|00001bf0| 61 64 65 72 2d 3e 64 69 | 72 5f 73 69 7a 65 3b 0d |ader->di|r_size;.|
|00001c00| 09 20 20 64 62 66 2d 3e | 68 65 61 64 65 72 2d 3e |. dbf->|header->|
|00001c10| 64 69 72 5f 73 69 7a 65 | 20 3d 20 64 69 72 5f 73 |dir_size| = dir_s|
|00001c20| 69 7a 65 3b 0d 09 20 20 | 64 62 66 2d 3e 68 65 61 |ize;.. |dbf->hea|
|00001c30| 64 65 72 2d 3e 64 69 72 | 5f 62 69 74 73 20 3d 20 |der->dir|_bits = |
|00001c40| 6e 65 77 5f 62 69 74 73 | 3b 0d 09 20 20 6f 6c 64 |new_bits|;.. old|
|00001c50| 5f 63 6f 75 6e 74 2b 2b | 3b 0d 09 20 20 0d 09 20 |_count++|;.. .. |
|00001c60| 20 2f 2a 20 4e 6f 77 20 | 75 70 64 61 74 65 20 64 | /* Now |update d|
|00001c70| 62 66 2e 20 20 2a 2f 0d | 09 20 20 64 62 66 2d 3e |bf. */.|. dbf->|
|00001c80| 68 65 61 64 65 72 5f 63 | 68 61 6e 67 65 64 20 3d |header_c|hanged =|
|00001c90| 20 54 52 55 45 3b 0d 09 | 20 20 64 62 66 2d 3e 62 | TRUE;..| dbf->b|
|00001ca0| 75 63 6b 65 74 5f 64 69 | 72 20 2a 3d 20 32 3b 0d |ucket_di|r *= 2;.|
|00001cb0| 09 20 20 66 72 65 65 20 | 28 64 62 66 2d 3e 64 69 |. free |(dbf->di|
|00001cc0| 72 29 3b 0d 09 20 20 64 | 62 66 2d 3e 64 69 72 20 |r);.. d|bf->dir |
|00001cd0| 3d 20 6e 65 77 5f 64 69 | 72 3b 0d 09 7d 0d 0d 20 |= new_di|r;..}.. |
|00001ce0| 20 20 20 20 20 2f 2a 20 | 43 6f 70 79 20 61 6c 6c | /* |Copy all|
|00001cf0| 20 65 6c 65 6d 65 6e 74 | 73 20 69 6e 20 64 62 66 | element|s in dbf|
|00001d00| 2d 3e 62 75 63 6b 65 74 | 20 69 6e 74 6f 20 74 68 |->bucket| into th|
|00001d10| 65 20 6e 65 77 20 62 75 | 63 6b 65 74 73 2e 20 2a |e new bu|ckets. *|
|00001d20| 2f 0d 20 20 20 20 20 20 | 66 6f 72 20 28 69 6e 64 |/. |for (ind|
|00001d30| 65 78 20 3d 20 30 3b 20 | 69 6e 64 65 78 20 3c 20 |ex = 0; |index < |
|00001d40| 64 62 66 2d 3e 68 65 61 | 64 65 72 2d 3e 62 75 63 |dbf->hea|der->buc|
|00001d50| 6b 65 74 5f 65 6c 65 6d | 73 3b 20 69 6e 64 65 78 |ket_elem|s; index|
|00001d60| 2b 2b 29 0d 09 7b 0d 09 | 20 20 6f 6c 64 5f 65 6c |++)..{..| old_el|
|00001d70| 20 3d 20 26 20 28 64 62 | 66 2d 3e 62 75 63 6b 65 | = & (db|f->bucke|
|00001d80| 74 2d 3e 68 5f 74 61 62 | 6c 65 5b 69 6e 64 65 78 |t->h_tab|le[index|
|00001d90| 5d 29 3b 0d 09 20 20 73 | 65 6c 65 63 74 20 3d 20 |]);.. s|elect = |
|00001da0| 28 6f 6c 64 5f 65 6c 2d | 3e 68 61 73 68 5f 76 61 |(old_el-|>hash_va|
|00001db0| 6c 75 65 20 3e 3e 20 28 | 33 31 2d 6e 65 77 5f 62 |lue >> (|31-new_b|
|00001dc0| 69 74 73 29 29 20 26 20 | 31 3b 0d 09 20 20 65 6c |its)) & |1;.. el|
|00001dd0| 65 6d 5f 6c 6f 63 20 3d | 20 6f 6c 64 5f 65 6c 2d |em_loc =| old_el-|
|00001de0| 3e 68 61 73 68 5f 76 61 | 6c 75 65 20 25 20 64 62 |>hash_va|lue % db|
|00001df0| 66 2d 3e 68 65 61 64 65 | 72 2d 3e 62 75 63 6b 65 |f->heade|r->bucke|
|00001e00| 74 5f 65 6c 65 6d 73 3b | 0d 09 20 20 77 68 69 6c |t_elems;|.. whil|
|00001e10| 65 20 28 62 75 63 6b 65 | 74 5b 73 65 6c 65 63 74 |e (bucke|t[select|
|00001e20| 5d 2d 3e 68 5f 74 61 62 | 6c 65 5b 65 6c 65 6d 5f |]->h_tab|le[elem_|
|00001e30| 6c 6f 63 5d 2e 68 61 73 | 68 5f 76 61 6c 75 65 20 |loc].has|h_value |
|00001e40| 21 3d 20 2d 31 29 0d 09 | 20 20 20 20 65 6c 65 6d |!= -1)..| elem|
|00001e50| 5f 6c 6f 63 20 3d 20 28 | 65 6c 65 6d 5f 6c 6f 63 |_loc = (|elem_loc|
|00001e60| 20 2b 20 31 29 20 25 20 | 64 62 66 2d 3e 68 65 61 | + 1) % |dbf->hea|
|00001e70| 64 65 72 2d 3e 62 75 63 | 6b 65 74 5f 65 6c 65 6d |der->buc|ket_elem|
|00001e80| 73 3b 0d 09 20 20 62 75 | 63 6b 65 74 5b 73 65 6c |s;.. bu|cket[sel|
|00001e90| 65 63 74 5d 2d 3e 68 5f | 74 61 62 6c 65 5b 65 6c |ect]->h_|table[el|
|00001ea0| 65 6d 5f 6c 6f 63 5d 20 | 3d 20 2a 6f 6c 64 5f 65 |em_loc] |= *old_e|
|00001eb0| 6c 3b 0d 09 20 20 62 75 | 63 6b 65 74 5b 73 65 6c |l;.. bu|cket[sel|
|00001ec0| 65 63 74 5d 2d 3e 63 6f | 75 6e 74 20 2b 3d 20 31 |ect]->co|unt += 1|
|00001ed0| 3b 0d 09 7d 0d 20 20 20 | 20 20 20 0d 20 20 20 20 |;..}. | . |
|00001ee0| 20 20 2f 2a 20 41 6c 6c | 6f 63 61 74 65 20 61 76 | /* All|ocate av|
|00001ef0| 61 69 6c 20 73 70 61 63 | 65 20 66 6f 72 20 74 68 |ail spac|e for th|
|00001f00| 65 20 62 75 63 6b 65 74 | 5b 31 5d 2e 20 2a 2f 0d |e bucket|[1]. */.|
|00001f10| 20 20 20 20 20 20 62 75 | 63 6b 65 74 5b 31 5d 2d | bu|cket[1]-|
|00001f20| 3e 62 75 63 6b 65 74 5f | 61 76 61 69 6c 5b 30 5d |>bucket_|avail[0]|
|00001f30| 2e 61 76 5f 61 64 72 0d | 09 3d 20 5f 67 64 62 6d |.av_adr.|.= _gdbm|
|00001f40| 5f 61 6c 6c 6f 63 20 28 | 64 62 66 2c 20 64 62 66 |_alloc (|dbf, dbf|
|00001f50| 2d 3e 68 65 61 64 65 72 | 2d 3e 62 6c 6f 63 6b 5f |->header|->block_|
|00001f60| 73 69 7a 65 29 3b 0d 20 | 20 20 20 20 20 62 75 63 |size);. | buc|
|00001f70| 6b 65 74 5b 31 5d 2d 3e | 62 75 63 6b 65 74 5f 61 |ket[1]->|bucket_a|
|00001f80| 76 61 69 6c 5b 30 5d 2e | 61 76 5f 73 69 7a 65 20 |vail[0].|av_size |
|00001f90| 3d 20 64 62 66 2d 3e 68 | 65 61 64 65 72 2d 3e 62 |= dbf->h|eader->b|
|00001fa0| 6c 6f 63 6b 5f 73 69 7a | 65 3b 0d 20 20 20 20 20 |lock_siz|e;. |
|00001fb0| 20 62 75 63 6b 65 74 5b | 31 5d 2d 3e 61 76 5f 63 | bucket[|1]->av_c|
|00001fc0| 6f 75 6e 74 20 3d 20 31 | 3b 0d 20 20 20 20 20 20 |ount = 1|;. |
|00001fd0| 0d 20 20 20 20 20 20 2f | 2a 20 43 6f 70 79 20 74 |. /|* Copy t|
|00001fe0| 68 65 20 61 76 61 69 6c | 20 65 6c 65 6d 65 6e 74 |he avail| element|
|00001ff0| 73 20 69 6e 20 64 62 66 | 2d 3e 62 75 63 6b 65 74 |s in dbf|->bucket|
|00002000| 20 74 6f 20 62 75 63 6b | 65 74 5b 30 5d 2e 20 2a | to buck|et[0]. *|
|00002010| 2f 0d 20 20 20 20 20 20 | 62 75 63 6b 65 74 5b 30 |/. |bucket[0|
|00002020| 5d 2d 3e 61 76 5f 63 6f | 75 6e 74 20 3d 20 64 62 |]->av_co|unt = db|
|00002030| 66 2d 3e 62 75 63 6b 65 | 74 2d 3e 61 76 5f 63 6f |f->bucke|t->av_co|
|00002040| 75 6e 74 3b 0d 20 20 20 | 20 20 20 69 6e 64 65 78 |unt;. | index|
|00002050| 20 3d 20 30 3b 0d 20 20 | 20 20 20 20 69 6e 64 65 | = 0;. | inde|
|00002060| 78 31 20 3d 20 30 3b 0d | 20 20 20 20 20 20 69 66 |x1 = 0;.| if|
|00002070| 20 28 62 75 63 6b 65 74 | 5b 30 5d 2d 3e 61 76 5f | (bucket|[0]->av_|
|00002080| 63 6f 75 6e 74 20 3d 3d | 20 42 55 43 4b 45 54 5f |count ==| BUCKET_|
|00002090| 41 56 41 49 4c 29 0d 09 | 7b 0d 09 20 20 2f 2a 20 |AVAIL)..|{.. /* |
|000020a0| 54 68 65 20 61 76 61 69 | 6c 20 69 73 20 66 75 6c |The avai|l is ful|
|000020b0| 6c 2c 20 6d 6f 76 65 20 | 74 68 65 20 66 69 72 73 |l, move |the firs|
|000020c0| 74 20 6f 6e 65 20 74 6f | 20 62 75 63 6b 65 74 5b |t one to| bucket[|
|000020d0| 31 5d 2e 20 2a 2f 0d 09 | 20 20 5f 67 64 62 6d 5f |1]. */..| _gdbm_|
|000020e0| 70 75 74 5f 61 76 5f 65 | 6c 65 6d 20 28 64 62 66 |put_av_e|lem (dbf|
|000020f0| 2d 3e 62 75 63 6b 65 74 | 2d 3e 62 75 63 6b 65 74 |->bucket|->bucket|
|00002100| 5f 61 76 61 69 6c 5b 30 | 5d 2c 0d 09 09 09 20 20 |_avail[0|],.... |
|00002110| 20 20 20 62 75 63 6b 65 | 74 5b 31 5d 2d 3e 62 75 | bucke|t[1]->bu|
|00002120| 63 6b 65 74 5f 61 76 61 | 69 6c 2c 0d 09 09 09 20 |cket_ava|il,.... |
|00002130| 20 20 20 20 26 62 75 63 | 6b 65 74 5b 31 5d 2d 3e | &buc|ket[1]->|
|00002140| 61 76 5f 63 6f 75 6e 74 | 29 3b 0d 09 20 20 69 6e |av_count|);.. in|
|00002150| 64 65 78 20 3d 20 31 3b | 0d 09 20 20 62 75 63 6b |dex = 1;|.. buck|
|00002160| 65 74 5b 30 5d 2d 3e 61 | 76 5f 63 6f 75 6e 74 20 |et[0]->a|v_count |
|00002170| 2d 2d 3b 0d 09 7d 0d 20 | 20 20 20 20 20 66 6f 72 |--;..}. | for|
|00002180| 20 28 3b 20 69 6e 64 65 | 78 20 3c 20 64 62 66 2d | (; inde|x < dbf-|
|00002190| 3e 62 75 63 6b 65 74 2d | 3e 61 76 5f 63 6f 75 6e |>bucket-|>av_coun|
|000021a0| 74 3b 20 69 6e 64 65 78 | 2b 2b 29 0d 09 7b 0d 09 |t; index|++)..{..|
|000021b0| 20 20 62 75 63 6b 65 74 | 5b 30 5d 2d 3e 62 75 63 | bucket|[0]->buc|
|000021c0| 6b 65 74 5f 61 76 61 69 | 6c 5b 69 6e 64 65 78 31 |ket_avai|l[index1|
|000021d0| 2b 2b 5d 20 3d 20 64 62 | 66 2d 3e 62 75 63 6b 65 |++] = db|f->bucke|
|000021e0| 74 2d 3e 62 75 63 6b 65 | 74 5f 61 76 61 69 6c 5b |t->bucke|t_avail[|
|000021f0| 69 6e 64 65 78 5d 3b 0d | 09 7d 0d 20 20 20 20 20 |index];.|.}. |
|00002200| 20 0d 20 20 20 20 20 20 | 2f 2a 20 55 70 64 61 74 | . |/* Updat|
|00002210| 65 20 74 68 65 20 64 69 | 72 65 63 74 6f 72 79 2e |e the di|rectory.|
|00002220| 20 20 57 65 20 68 61 76 | 65 20 6e 65 77 20 66 69 | We hav|e new fi|
|00002230| 6c 65 20 61 64 64 72 65 | 73 73 65 73 20 66 6f 72 |le addre|sses for|
|00002240| 20 62 6f 74 68 20 62 75 | 63 6b 65 74 73 2e 20 2a | both bu|ckets. *|
|00002250| 2f 0d 20 20 20 20 20 20 | 64 69 72 5f 73 74 61 72 |/. |dir_star|
|00002260| 74 31 20 3d 20 28 64 62 | 66 2d 3e 62 75 63 6b 65 |t1 = (db|f->bucke|
|00002270| 74 5f 64 69 72 20 3e 3e | 20 28 64 62 66 2d 3e 68 |t_dir >>| (dbf->h|
|00002280| 65 61 64 65 72 2d 3e 64 | 69 72 5f 62 69 74 73 20 |eader->d|ir_bits |
|00002290| 2d 20 6e 65 77 5f 62 69 | 74 73 29 29 20 7c 20 31 |- new_bi|ts)) | 1|
|000022a0| 3b 0d 20 20 20 20 20 20 | 64 69 72 5f 65 6e 64 20 |;. |dir_end |
|000022b0| 3d 20 28 64 69 72 5f 73 | 74 61 72 74 31 20 2b 20 |= (dir_s|tart1 + |
|000022c0| 31 29 20 3c 3c 20 28 64 | 62 66 2d 3e 68 65 61 64 |1) << (d|bf->head|
|000022d0| 65 72 2d 3e 64 69 72 5f | 62 69 74 73 20 2d 20 6e |er->dir_|bits - n|
|000022e0| 65 77 5f 62 69 74 73 29 | 3b 0d 20 20 20 20 20 20 |ew_bits)|;. |
|000022f0| 64 69 72 5f 73 74 61 72 | 74 31 20 3d 20 64 69 72 |dir_star|t1 = dir|
|00002300| 5f 73 74 61 72 74 31 20 | 3c 3c 20 28 64 62 66 2d |_start1 |<< (dbf-|
|00002310| 3e 68 65 61 64 65 72 2d | 3e 64 69 72 5f 62 69 74 |>header-|>dir_bit|
|00002320| 73 20 2d 20 6e 65 77 5f | 62 69 74 73 29 3b 0d 20 |s - new_|bits);. |
|00002330| 20 20 20 20 20 64 69 72 | 5f 73 74 61 72 74 30 20 | dir|_start0 |
|00002340| 3d 20 64 69 72 5f 73 74 | 61 72 74 31 20 2d 20 28 |= dir_st|art1 - (|
|00002350| 64 69 72 5f 65 6e 64 20 | 2d 20 64 69 72 5f 73 74 |dir_end |- dir_st|
|00002360| 61 72 74 31 29 3b 0d 20 | 20 20 20 20 20 66 6f 72 |art1);. | for|
|00002370| 20 28 69 6e 64 65 78 20 | 3d 20 64 69 72 5f 73 74 | (index |= dir_st|
|00002380| 61 72 74 30 3b 20 69 6e | 64 65 78 20 3c 20 64 69 |art0; in|dex < di|
|00002390| 72 5f 73 74 61 72 74 31 | 3b 20 69 6e 64 65 78 2b |r_start1|; index+|
|000023a0| 2b 29 0d 09 64 62 66 2d | 3e 64 69 72 5b 69 6e 64 |+)..dbf-|>dir[ind|
|000023b0| 65 78 5d 20 3d 20 61 64 | 72 5f 30 3b 0d 20 20 20 |ex] = ad|r_0;. |
|000023c0| 20 20 20 66 6f 72 20 28 | 69 6e 64 65 78 20 3d 20 | for (|index = |
|000023d0| 64 69 72 5f 73 74 61 72 | 74 31 3b 20 69 6e 64 65 |dir_star|t1; inde|
|000023e0| 78 20 3c 20 64 69 72 5f | 65 6e 64 3b 20 69 6e 64 |x < dir_|end; ind|
|000023f0| 65 78 2b 2b 29 0d 09 64 | 62 66 2d 3e 64 69 72 5b |ex++)..d|bf->dir[|
|00002400| 69 6e 64 65 78 5d 20 3d | 20 61 64 72 5f 31 3b 0d |index] =| adr_1;.|
|00002410| 20 20 20 20 20 20 0d 20 | 20 20 20 20 20 0d 20 20 | . | . |
|00002420| 20 20 20 20 2f 2a 20 53 | 65 74 20 63 68 61 6e 67 | /* S|et chang|
|00002430| 65 64 20 66 6c 61 67 73 | 2e 20 2a 2f 0d 20 20 20 |ed flags|. */. |
|00002440| 20 20 20 64 62 66 2d 3e | 62 75 63 6b 65 74 5f 63 | dbf->|bucket_c|
|00002450| 61 63 68 65 5b 63 61 63 | 68 65 5f 30 5d 2e 63 61 |ache[cac|he_0].ca|
|00002460| 5f 63 68 61 6e 67 65 64 | 20 3d 20 54 52 55 45 3b |_changed| = TRUE;|
|00002470| 0d 20 20 20 20 20 20 64 | 62 66 2d 3e 62 75 63 6b |. d|bf->buck|
|00002480| 65 74 5f 63 61 63 68 65 | 5b 63 61 63 68 65 5f 31 |et_cache|[cache_1|
|00002490| 5d 2e 63 61 5f 63 68 61 | 6e 67 65 64 20 3d 20 54 |].ca_cha|nged = T|
|000024a0| 52 55 45 3b 0d 20 20 20 | 20 20 20 64 62 66 2d 3e |RUE;. | dbf->|
|000024b0| 62 75 63 6b 65 74 5f 63 | 68 61 6e 67 65 64 20 3d |bucket_c|hanged =|
|000024c0| 20 54 52 55 45 3b 0d 20 | 20 20 20 20 20 64 62 66 | TRUE;. | dbf|
|000024d0| 2d 3e 64 69 72 65 63 74 | 6f 72 79 5f 63 68 61 6e |->direct|ory_chan|
|000024e0| 67 65 64 20 3d 20 54 52 | 55 45 3b 0d 20 20 20 20 |ged = TR|UE;. |
|000024f0| 20 20 64 62 66 2d 3e 73 | 65 63 6f 6e 64 5f 63 68 | dbf->s|econd_ch|
|00002500| 61 6e 67 65 64 20 3d 20 | 54 52 55 45 3b 0d 20 20 |anged = |TRUE;. |
|00002510| 20 20 20 20 0d 20 20 20 | 20 20 20 2f 2a 20 55 70 | . | /* Up|
|00002520| 64 61 74 65 20 74 68 65 | 20 63 61 63 68 65 21 20 |date the| cache! |
|00002530| 2a 2f 0d 20 20 20 20 20 | 20 64 62 66 2d 3e 62 75 |*/. | dbf->bu|
|00002540| 63 6b 65 74 5f 64 69 72 | 20 3d 20 6e 65 78 74 5f |cket_dir| = next_|
|00002550| 69 6e 73 65 72 74 20 3e | 3e 20 28 33 31 2d 64 62 |insert >|> (31-db|
|00002560| 66 2d 3e 68 65 61 64 65 | 72 2d 3e 64 69 72 5f 62 |f->heade|r->dir_b|
|00002570| 69 74 73 29 3b 0d 20 20 | 20 20 20 20 0d 20 20 20 |its);. | . |
|00002580| 20 20 20 2f 2a 20 49 6e | 76 61 6c 69 64 61 74 65 | /* In|validate|
|00002590| 20 6f 6c 64 20 63 61 63 | 68 65 20 65 6e 74 72 79 | old cac|he entry|
|000025a0| 2e 20 2a 2f 0d 20 20 20 | 20 20 20 6f 6c 64 5f 62 |. */. | old_b|
|000025b0| 75 63 6b 65 74 2e 61 76 | 5f 61 64 72 20 20 3d 20 |ucket.av|_adr = |
|000025c0| 64 62 66 2d 3e 63 61 63 | 68 65 5f 65 6e 74 72 79 |dbf->cac|he_entry|
|000025d0| 2d 3e 63 61 5f 61 64 72 | 3b 0d 20 20 20 20 20 20 |->ca_adr|;. |
|000025e0| 6f 6c 64 5f 62 75 63 6b | 65 74 2e 61 76 5f 73 69 |old_buck|et.av_si|
|000025f0| 7a 65 20 3d 20 64 62 66 | 2d 3e 68 65 61 64 65 72 |ze = dbf|->header|
|00002600| 2d 3e 62 75 63 6b 65 74 | 5f 73 69 7a 65 3b 0d 20 |->bucket|_size;. |
|00002610| 20 20 20 20 20 64 62 66 | 2d 3e 63 61 63 68 65 5f | dbf|->cache_|
|00002620| 65 6e 74 72 79 2d 3e 63 | 61 5f 61 64 72 20 3d 20 |entry->c|a_adr = |
|00002630| 30 3b 0d 20 20 20 20 20 | 20 64 62 66 2d 3e 63 61 |0;. | dbf->ca|
|00002640| 63 68 65 5f 65 6e 74 72 | 79 2d 3e 63 61 5f 63 68 |che_entr|y->ca_ch|
|00002650| 61 6e 67 65 64 20 3d 20 | 46 41 4c 53 45 3b 0d 20 |anged = |FALSE;. |
|00002660| 20 20 20 20 20 0d 20 20 | 20 20 20 20 2f 2a 20 53 | . | /* S|
|00002670| 65 74 20 64 62 66 2d 3e | 62 75 63 6b 65 74 20 74 |et dbf->|bucket t|
|00002680| 6f 20 74 68 65 20 70 72 | 6f 70 65 72 20 62 75 63 |o the pr|oper buc|
|00002690| 6b 65 74 2e 20 2a 2f 0d | 20 20 20 20 20 20 69 66 |ket. */.| if|
|000026a0| 20 28 64 62 66 2d 3e 64 | 69 72 5b 64 62 66 2d 3e | (dbf->d|ir[dbf->|
|000026b0| 62 75 63 6b 65 74 5f 64 | 69 72 5d 20 3d 3d 20 61 |bucket_d|ir] == a|
|000026c0| 64 72 5f 30 29 0d 09 7b | 0d 09 20 20 64 62 66 2d |dr_0)..{|.. dbf-|
|000026d0| 3e 62 75 63 6b 65 74 20 | 3d 20 62 75 63 6b 65 74 |>bucket |= bucket|
|000026e0| 5b 30 5d 3b 0d 09 20 20 | 64 62 66 2d 3e 63 61 63 |[0];.. |dbf->cac|
|000026f0| 68 65 5f 65 6e 74 72 79 | 20 3d 20 26 64 62 66 2d |he_entry| = &dbf-|
|00002700| 3e 62 75 63 6b 65 74 5f | 63 61 63 68 65 5b 63 61 |>bucket_|cache[ca|
|00002710| 63 68 65 5f 30 5d 3b 0d | 09 20 20 5f 67 64 62 6d |che_0];.|. _gdbm|
|00002720| 5f 70 75 74 5f 61 76 5f | 65 6c 65 6d 20 28 6f 6c |_put_av_|elem (ol|
|00002730| 64 5f 62 75 63 6b 65 74 | 2c 0d 09 09 09 20 20 20 |d_bucket|,.... |
|00002740| 20 20 62 75 63 6b 65 74 | 5b 31 5d 2d 3e 62 75 63 | bucket|[1]->buc|
|00002750| 6b 65 74 5f 61 76 61 69 | 6c 2c 0d 09 09 09 20 20 |ket_avai|l,.... |
|00002760| 20 20 20 26 62 75 63 6b | 65 74 5b 31 5d 2d 3e 61 | &buck|et[1]->a|
|00002770| 76 5f 63 6f 75 6e 74 29 | 3b 0d 09 7d 0d 20 20 20 |v_count)|;..}. |
|00002780| 20 20 20 65 6c 73 65 0d | 09 7b 0d 09 20 20 64 62 | else.|.{.. db|
|00002790| 66 2d 3e 62 75 63 6b 65 | 74 20 3d 20 62 75 63 6b |f->bucke|t = buck|
|000027a0| 65 74 5b 31 5d 3b 0d 09 | 20 20 64 62 66 2d 3e 63 |et[1];..| dbf->c|
|000027b0| 61 63 68 65 5f 65 6e 74 | 72 79 20 3d 20 26 64 62 |ache_ent|ry = &db|
|000027c0| 66 2d 3e 62 75 63 6b 65 | 74 5f 63 61 63 68 65 5b |f->bucke|t_cache[|
|000027d0| 63 61 63 68 65 5f 31 5d | 3b 0d 09 20 20 5f 67 64 |cache_1]|;.. _gd|
|000027e0| 62 6d 5f 70 75 74 5f 61 | 76 5f 65 6c 65 6d 20 28 |bm_put_a|v_elem (|
|000027f0| 6f 6c 64 5f 62 75 63 6b | 65 74 2c 0d 09 09 09 20 |old_buck|et,.... |
|00002800| 20 20 20 20 62 75 63 6b | 65 74 5b 30 5d 2d 3e 62 | buck|et[0]->b|
|00002810| 75 63 6b 65 74 5f 61 76 | 61 69 6c 2c 0d 09 09 09 |ucket_av|ail,....|
|00002820| 20 20 20 20 20 26 62 75 | 63 6b 65 74 5b 30 5d 2d | &bu|cket[0]-|
|00002830| 3e 61 76 5f 63 6f 75 6e | 74 29 3b 0d 09 7d 0d 20 |>av_coun|t);..}. |
|00002840| 20 20 20 20 20 0d 20 20 | 20 20 7d 0d 0d 20 20 2f | . | }.. /|
|00002850| 2a 20 47 65 74 20 72 69 | 64 20 6f 66 20 6f 6c 64 |* Get ri|d of old|
|00002860| 20 64 69 72 65 63 74 6f | 72 69 65 73 2e 20 2a 2f | directo|ries. */|
|00002870| 0d 20 20 66 6f 72 20 28 | 69 6e 64 65 78 20 3d 20 |. for (|index = |
|00002880| 30 3b 20 69 6e 64 65 78 | 20 3c 20 6f 6c 64 5f 63 |0; index| < old_c|
|00002890| 6f 75 6e 74 3b 20 69 6e | 64 65 78 2b 2b 29 0d 20 |ount; in|dex++). |
|000028a0| 20 20 20 5f 67 64 62 6d | 5f 66 72 65 65 20 28 64 | _gdbm|_free (d|
|000028b0| 62 66 2c 20 6f 6c 64 5f | 61 64 72 5b 69 6e 64 65 |bf, old_|adr[inde|
|000028c0| 78 5d 2c 20 6f 6c 64 5f | 73 69 7a 65 5b 69 6e 64 |x], old_|size[ind|
|000028d0| 65 78 5d 29 3b 0d 7d 0d | 0d 0d 2f 2a 20 54 68 65 |ex]);.}.|../* The|
|000028e0| 20 6f 6e 6c 79 20 70 6c | 61 63 65 20 77 68 65 72 | only pl|ace wher|
|000028f0| 65 20 61 20 62 75 63 6b | 65 74 20 69 73 20 77 72 |e a buck|et is wr|
|00002900| 69 74 74 65 6e 2e 20 20 | 43 41 5f 45 4e 54 52 59 |itten. |CA_ENTRY|
|00002910| 20 69 73 20 74 68 65 0d | 20 20 20 63 61 63 68 65 | is the.| cache|
|00002920| 20 65 6e 74 72 79 20 63 | 6f 6e 74 61 69 6e 69 6e | entry c|ontainin|
|00002930| 67 20 74 68 65 20 62 75 | 63 6b 65 74 20 74 6f 20 |g the bu|cket to |
|00002940| 62 65 20 77 72 69 74 74 | 65 6e 2e 20 2a 2f 0d 0d |be writt|en. */..|
|00002950| 5f 67 64 62 6d 5f 77 72 | 69 74 65 5f 62 75 63 6b |_gdbm_wr|ite_buck|
|00002960| 65 74 20 28 64 62 66 2c | 20 63 61 5f 65 6e 74 72 |et (dbf,| ca_entr|
|00002970| 79 29 0d 20 20 20 20 20 | 67 64 62 6d 5f 66 69 6c |y). |gdbm_fil|
|00002980| 65 5f 69 6e 66 6f 20 2a | 64 62 66 3b 0d 20 20 20 |e_info *|dbf;. |
|00002990| 20 20 63 61 63 68 65 5f | 65 6c 65 6d 20 2a 63 61 | cache_|elem *ca|
|000029a0| 5f 65 6e 74 72 79 3b 0d | 7b 0d 20 20 69 6e 74 20 |_entry;.|{. int |
|000029b0| 20 6e 75 6d 5f 62 79 74 | 65 73 3b 09 2f 2a 20 54 | num_byt|es;./* T|
|000029c0| 68 65 20 72 65 74 75 72 | 6e 20 76 61 6c 75 65 20 |he retur|n value |
|000029d0| 66 6f 72 20 77 72 69 74 | 65 2e 20 2a 2f 0d 20 20 |for writ|e. */. |
|000029e0| 6c 6f 6e 67 20 66 69 6c | 65 5f 70 6f 73 3b 09 2f |long fil|e_pos;./|
|000029f0| 2a 20 54 68 65 20 72 65 | 74 75 72 6e 20 76 61 6c |* The re|turn val|
|00002a00| 75 65 20 66 6f 72 20 6c | 73 65 65 6b 2e 20 2a 2f |ue for l|seek. */|
|00002a10| 0d 20 20 0d 20 20 66 69 | 6c 65 5f 70 6f 73 20 3d |. . fi|le_pos =|
|00002a20| 20 6c 73 65 65 6b 20 28 | 64 62 66 2d 3e 64 65 73 | lseek (|dbf->des|
|00002a30| 63 2c 20 63 61 5f 65 6e | 74 72 79 2d 3e 63 61 5f |c, ca_en|try->ca_|
|00002a40| 61 64 72 2c 20 4c 5f 53 | 45 54 29 3b 0d 20 20 69 |adr, L_S|ET);. i|
|00002a50| 66 20 28 66 69 6c 65 5f | 70 6f 73 20 21 3d 20 63 |f (file_|pos != c|
|00002a60| 61 5f 65 6e 74 72 79 2d | 3e 63 61 5f 61 64 72 29 |a_entry-|>ca_adr)|
|00002a70| 0d 20 20 20 20 5f 67 64 | 62 6d 5f 66 61 74 61 6c |. _gd|bm_fatal|
|00002a80| 20 28 64 62 66 2c 20 22 | 6c 73 65 65 6b 20 65 72 | (dbf, "|lseek er|
|00002a90| 72 6f 72 22 29 3b 0d 20 | 20 6e 75 6d 5f 62 79 74 |ror");. | num_byt|
|00002aa0| 65 73 20 3d 20 77 72 69 | 74 65 20 28 64 62 66 2d |es = wri|te (dbf-|
|00002ab0| 3e 64 65 73 63 2c 20 28 | 63 68 61 72 20 2a 29 20 |>desc, (|char *) |
|00002ac0| 63 61 5f 65 6e 74 72 79 | 2d 3e 63 61 5f 62 75 63 |ca_entry|->ca_buc|
|00002ad0| 6b 65 74 2c 20 64 62 66 | 2d 3e 68 65 61 64 65 72 |ket, dbf|->header|
|00002ae0| 2d 3e 62 75 63 6b 65 74 | 5f 73 69 7a 65 29 3b 0d |->bucket|_size);.|
|00002af0| 20 20 69 66 20 28 6e 75 | 6d 5f 62 79 74 65 73 20 | if (nu|m_bytes |
|00002b00| 21 3d 20 64 62 66 2d 3e | 68 65 61 64 65 72 2d 3e |!= dbf->|header->|
|00002b10| 62 75 63 6b 65 74 5f 73 | 69 7a 65 29 0d 20 20 20 |bucket_s|ize). |
|00002b20| 20 5f 67 64 62 6d 5f 66 | 61 74 61 6c 20 28 64 62 | _gdbm_f|atal (db|
|00002b30| 66 2c 20 22 77 72 69 74 | 65 20 65 72 72 6f 72 22 |f, "writ|e error"|
|00002b40| 29 3b 0d 20 20 63 61 5f | 65 6e 74 72 79 2d 3e 63 |);. ca_|entry->c|
|00002b50| 61 5f 63 68 61 6e 67 65 | 64 20 3d 20 46 41 4c 53 |a_change|d = FALS|
|00002b60| 45 3b 0d 20 20 63 61 5f | 65 6e 74 72 79 2d 3e 63 |E;. ca_|entry->c|
|00002b70| 61 5f 64 61 74 61 2e 68 | 61 73 68 5f 76 61 6c 20 |a_data.h|ash_val |
|00002b80| 3d 20 2d 31 3b 0d 20 20 | 63 61 5f 65 6e 74 72 79 |= -1;. |ca_entry|
|00002b90| 2d 3e 63 61 5f 64 61 74 | 61 2e 65 6c 65 6d 5f 6c |->ca_dat|a.elem_l|
|00002ba0| 6f 63 20 3d 20 2d 31 3b | 0d 20 20 0d 7d 0d 00 00 |oc = -1;|. .}...|
|00002bb0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002bc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002bd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002be0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002bf0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c00| 00 00 01 00 00 00 01 6e | 00 00 00 6e 00 00 00 3e |.......n|...n...>|
|00002c10| 69 74 68 6f 75 74 20 65 | 76 65 6e 20 74 68 65 20 |ithout e|ven the |
|00002c20| 69 6d 70 6c 69 65 64 20 | 77 61 72 72 61 6e 74 79 |implied |warranty|
|00002c30| 08 62 75 63 6b 65 74 2e | 63 00 02 00 00 00 00 00 |.bucket.|c.......|
|00002c40| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c50| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c60| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002c70| 00 00 a6 ea ac f0 00 00 | 2b 2e 00 00 01 ac 47 65 |........|+.....Ge|
|00002c80| 6e 65 72 61 6c 20 50 75 | 62 6c 69 63 20 4c 69 63 |neral Pu|blic Lic|
|00002c90| 65 6e 73 65 20 66 6f 72 | 20 6d 6f 72 65 20 64 65 |ense for| more de|
|00002ca0| 74 61 69 6c 73 2e 0d 0d | 20 20 20 20 59 6f 75 20 |tails...| You |
|00002cb0| 73 68 6f 75 6c 64 20 68 | 61 76 65 20 72 65 63 65 |should h|ave rece|
|00002cc0| 69 76 65 64 20 61 20 63 | 6f 70 79 20 6f 66 20 74 |ived a c|opy of t|
|00002cd0| 68 65 20 47 4e 55 20 47 | 65 6e 65 72 61 6c 20 50 |he GNU G|eneral P|
|00002ce0| 75 62 6c 69 63 20 4c 69 | 63 65 6e 73 65 0d 20 20 |ublic Li|cense. |
|00002cf0| 20 20 61 6c 6f 6e 67 20 | 77 69 74 68 20 47 44 42 | along |with GDB|
|00002d00| 00 00 00 48 00 09 4d 6f | 6e 61 63 6f 00 65 74 73 |...H..Mo|naco.ets|
|00002d10| 2e 20 2a 2f 0d 0d 2f 2a | 20 20 54 68 69 73 20 66 |. */../*| This f|
|00002d20| 69 6c 65 20 69 73 00 06 | 00 08 00 78 00 18 01 dd |ile is..|...x....|
|00002d30| 02 3d 00 78 00 18 01 dd | 02 3d a6 04 b7 3e 00 00 |.=.x....|.=...>..|
|00002d40| 0b 2b 00 00 0b 3a 00 00 | 0a 30 01 00 00 00 00 1e |.+...:..|.0......|
|00002d50| 00 78 00 18 01 dd 02 3d | 00 78 00 18 01 dd 02 3d |.x.....=|.x.....=|
|00002d60| 00 00 0a 30 00 00 00 00 | 00 00 00 00 00 00 00 00 |...0....|........|
|00002d70| 01 00 00 00 01 6e 00 00 | 00 6e 00 00 00 3e 00 54 |.....n..|.n...>.T|
|00002d80| 46 a4 0c dc 00 00 00 1c | 00 3e 00 00 4d 50 53 52 |F.......|.>..MPSR|
|00002d90| 00 01 00 0a 03 ed ff ff | 00 00 00 00 00 00 00 00 |........|........|
|00002da0| 03 f0 ff ff 00 00 00 4c | 00 5a 6b 38 00 00 00 00 |.......L|.Zk8....|
|00002db0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002dc0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002dd0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002de0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002df0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+